গ্রাফস (Graphs)

Computer Science - ডাটা স্ট্রাকচার & অ্যালগরিদম (Data Structure & Algorithms)
430

গ্রাফ (Graph) একটি জটিল ডেটা স্ট্রাকচার যা একটি সেট নোড (vertices) এবং তাদের মধ্যে সংযোগ (edges) নিয়ে গঠিত। এটি একটি হায়ারার্কিক্যাল বা নেটওয়ার্ক স্ট্রাকচার প্রদর্শন করতে ব্যবহৃত হয়, যেখানে নোডগুলি কিছু ডেটা ধারণ করে এবং সংযোগগুলি তাদের মধ্যে সম্পর্ক নির্দেশ করে। গ্রাফগুলি বিভিন্ন বাস্তব জীবনের সমস্যার সমাধানে ব্যাপকভাবে ব্যবহৃত হয়।

গ্রাফের মৌলিক উপাদান

  1. নোড (Node/Vertex): গ্রাফের মৌলিক ইউনিট। এটি একটি ডেটা ধারণ করে।
  2. এজ (Edge): দুটি নোডের মধ্যে সংযোগ। এটি একটি সম্পর্ক বা সংযোগ নির্দেশ করে।

গ্রাফের প্রকারভেদ

গ্রাফ সাধারণত বিভিন্ন উপায়ে শ্রেণীবদ্ধ করা হয়:

১.ডিরেক্টেড গ্রাফ (Directed Graph): যেখানে সংযোগগুলির একটি নির্দিষ্ট দিক থাকে। উদাহরণস্বরূপ, একটি সোশ্যাল মিডিয়া ফলোয়ার রিলেশনশিপ।

  • উদাহরণ: A → B (A থেকে B পর্যন্ত একটি দিক রয়েছে)।

২. আনডিরেক্টেড গ্রাফ (Undirected Graph): যেখানে সংযোগগুলির কোনো নির্দিষ্ট দিক নেই। অর্থাৎ, A থেকে B এবং B থেকে A উভয়ই হতে পারে।

  • উদাহরণ: A — B (A এবং B এর মধ্যে সংযোগ)।

৩. ওয়েটেড গ্রাফ (Weighted Graph): যেখানে প্রতিটি এজের একটি মান (ওজন) থাকে, যা সেই সংযোগের গুরুত্ব বা দূরত্ব নির্দেশ করে।

  • উদাহরণ: গ্রাফে শহরের মধ্যে দূরত্ব বোঝাতে।

৪. আনওয়েটেড গ্রাফ (Unweighted Graph): যেখানে সংযোগগুলির কোনো ওজন নেই।

৫. সাইক্লিক গ্রাফ (Cyclic Graph): যেখানে একটি বা একাধিক সাইকেল বা লুপ থাকে, অর্থাৎ, আপনি একটি নোড থেকে শুরু করে পুনরায় সেই নোডে ফিরে আসতে পারেন।

৬. এসি ক্লিক গ্রাফ (Acyclic Graph): যেখানে কোনো সাইকেল নেই।

গ্রাফের কার্যকারিতা

গ্রাফের বিভিন্ন কার্যকলাপ রয়েছে, যার মধ্যে কিছু হল:

১. গ্রাফ তৈরি (Graph Creation): নোড এবং এজ যোগ করা।

২. গ্রাফ ট্রাভার্সাল (Graph Traversal): গ্রাফের সমস্ত নোড ভিজিট করা। সাধারণত ব্যবহৃত পদ্ধতি:

  • ব্রেডথ-ফার্স্ট সার্চ (BFS): গ্রাফের নোডগুলিকে স্তরভিত্তিকভাবে ভিজিট করে।
  • ডেপথ-ফার্স্ট সার্চ (DFS): একটি শাখা অনুসরণ করে যতক্ষণ না সম্ভব হলে, তারপর পরবর্তী শাখায় চলে যায়।

৩.  নির্দিষ্ট পথ খোঁজা: গ্রাফের মধ্যে একটি নির্দিষ্ট নোড থেকে অন্য নোড পর্যন্ত পথ খুঁজে বের করা। যেমন:

  • ডাইজনস্ট্রা অ্যালগরিদম: সবচেয়ে সংক্ষিপ্ত পথ খুঁজে বের করতে ব্যবহৃত হয়।

উদাহরণ (পাইথনে একটি গ্রাফ)

class Graph:
    def __init__(self):
        self.graph = {}

    def add_edge(self, u, v):
        if u not in self.graph:
            self.graph[u] = []
        self.graph[u].append(v)

    def bfs(self, start):
        visited = set()
        queue = [start]

        while queue:
            vertex = queue.pop(0)
            if vertex not in visited:
                print(vertex, end=" ")
                visited.add(vertex)
                queue.extend(set(self.graph[vertex]) - visited)

    def dfs(self, start, visited=None):
        if visited is None:
            visited = set()
        visited.add(start)
        print(start, end=" ")
        for neighbor in self.graph.get(start, []):
            if neighbor not in visited:
                self.dfs(neighbor, visited)

# ব্যবহার
g = Graph()
g.add_edge(1, 2)
g.add_edge(1, 3)
g.add_edge(2, 4)
g.add_edge(3, 4)

print("BFS traversal starting from vertex 1:")
g.bfs(1)  # আউটপুট: 1 2 3 4

print("\nDFS traversal starting from vertex 1:")
g.dfs(1)  # আউটপুট: 1 2 4 3

উপসংহার

গ্রাফ একটি শক্তিশালী ডেটা স্ট্রাকচার যা বিভিন্ন পরিস্থিতিতে সম্পর্ক এবং নেটওয়ার্কের তথ্য উপস্থাপন করতে ব্যবহৃত হয়। এটি সোশ্যাল মিডিয়া, রাস্তা ও নেভিগেশন সিস্টেম, ওয়েব পেজের সংযোগ ইত্যাদিতে গুরুত্বপূর্ণ ভূমিকা পালন করে। গ্রাফের মাধ্যমে জটিল সম্পর্ক এবং তথ্যের কার্যকরী বিশ্লেষণ সম্ভব হয়।

গ্রাফের ধারণা এবং প্রকারভেদ: Directed, Undirected, Weighted, Unweighted

156

গ্রাফের ধারণা

গ্রাফ হলো একটি গাণিতিক ডেটা স্ট্রাকচার যা একটি সেট অব ভেরটেক্স (বা নোড) এবং এজ (বা সংযোগ) দ্বারা গঠিত। প্রতিটি নোড ডেটা ধারণ করে এবং সংযোগগুলি নোডগুলির মধ্যে সম্পর্ক নির্দেশ করে। গ্রাফের মাধ্যমে বিভিন্ন বাস্তব জীবনের সমস্যার মডেলিং করা যায়, যেমন সোশ্যাল নেটওয়ার্ক, রাস্তা, কম্পিউটার নেটওয়ার্ক ইত্যাদি।

গ্রাফ সাধারণত দুটি সেট দ্বারা সংজ্ঞায়িত করা হয়:

  1. V (Vertices বা Nodes): গ্রাফের মূল উপাদান বা বিন্দু।
  2. E (Edges): নোডগুলোর মধ্যে সংযোগ।

গ্রাফের প্রকারভেদ

গ্রাফের বিভিন্ন প্রকার রয়েছে এবং তারা বিভিন্ন ক্ষেত্রে ব্যবহার করা হয়। নিচে প্রধান কয়েকটি প্রকারের আলোচনা করা হলো:


১. Directed Graph (নির্দেশিত গ্রাফ)

একটি Directed Graph (বা Digraph) হলো এমন একটি গ্রাফ যেখানে প্রতিটি এজ একটি নির্দিষ্ট দিক নির্দেশ করে। একে দিকনির্দেশিত গ্রাফ বলা হয়। এখানে প্রতিটি সংযোগের জন্য একটি নির্দিষ্ট উৎস (source) এবং গন্তব্য (destination) থাকে।

  • প্রতিটি এজের দিক থাকে, যা গ্রাফের নির্দিষ্ট পথ নির্দেশ করে।
  • দিকনির্দেশিত গ্রাফের এজগুলো একতরফা হয়, অর্থাৎ A থেকে B তে যেতে পারলেও B থেকে A তে যাওয়া নাও যেতে পারে।

ব্যবহার ক্ষেত্র: সোশ্যাল নেটওয়ার্কের ফলোয়ার ব্যবস্থা, ওয়েব পেজের হাইপারলিঙ্ক, রাস্তার ট্রাফিক নির্দেশনা।

উদাহরণ:

A → B → C

২. Undirected Graph (অনির্দেশিত গ্রাফ)

একটি Undirected Graph হলো এমন একটি গ্রাফ যেখানে এজগুলোর কোনো নির্দিষ্ট দিক থাকে না। এখানে সংযোগ উভয় দিকেই কাজ করে, অর্থাৎ A থেকে B এবং B থেকে A উভয় পথেই যাতায়াত করা যায়।

  • এজগুলো দ্বিমুখী, অর্থাৎ সংযোগের উভয় দিকে যাতায়াত করা যায়।
  • সাধারণত সম্পর্ক বা পারস্পরিক সংযোগ নির্দেশ করতে ব্যবহার করা হয়।

ব্যবহার ক্ষেত্র: বন্ধুদের সম্পর্ক, রাস্তার ম্যাপ যেখানে যেকোনো দিকে যাতায়াত সম্ভব।

উদাহরণ:

A — B — C

৩. Weighted Graph (ওজনযুক্ত গ্রাফ)

একটি Weighted Graph হলো এমন একটি গ্রাফ যেখানে প্রতিটি এজের একটি নির্দিষ্ট ওজন বা মূল্য থাকে। এই ওজন সাধারণত দূরত্ব, সময় বা খরচ নির্দেশ করে। Weighted গ্রাফের মাধ্যমে এমন সমস্যাগুলোর মডেলিং করা হয় যেখানে সংযোগের গুরুত্ব বা খরচ রয়েছে।

  • প্রতিটি এজের ওজন থাকে, যা সাধারণত সংযোগের খরচ বা দূরত্ব নির্দেশ করে।
  • এই ধরনের গ্রাফে A থেকে B তে যাওয়ার বিভিন্ন পাথের তুলনা করা যায়, যার ফলে সবচেয়ে কম খরচের পথ খুঁজে বের করা সম্ভব হয়।

ব্যবহার ক্ষেত্র: রাস্তার মানচিত্র, যেখানে বিভিন্ন রাস্তার দূরত্ব বিভিন্ন।

উদাহরণ:

A —(3)— B —(5)— C

৪. Unweighted Graph (ওজনবিহীন গ্রাফ)

একটি Unweighted Graph হলো এমন একটি গ্রাফ যেখানে প্রতিটি এজের কোনো ওজন থাকে না। এটি সাধারণত এমন ক্ষেত্রে ব্যবহৃত হয় যেখানে সংযোগের গুরুত্ব বা খরচ নেই।

  • এজগুলো ওজনহীন, অর্থাৎ প্রতিটি সংযোগ একই রকমের গুরুত্ব বহন করে।
  • দ্রুত এবং সহজ গ্রাফ মডেলিংয়ের জন্য এটি কার্যকরী।

ব্যবহার ক্ষেত্র: সাধারণ সংযোগের ক্ষেত্র, যেমন নেটওয়ার্কিং টপোলজি যেখানে সংযোগের দূরত্ব বা খরচ নেই।

উদাহরণ:

A — B — C

গ্রাফের প্রকারভেদের তুলনামূলক চার্ট

গ্রাফের প্রকারবৈশিষ্ট্যউদাহরণ
Directed Graphএজগুলোর দিক থাকে, একমুখী সংযোগসোশ্যাল মিডিয়া ফলোয়ার, রাস্তার দিক নির্দেশ
Undirected Graphএজগুলোর কোনো নির্দিষ্ট দিক নেই, দ্বিমুখী সংযোগবন্ধুদের সম্পর্ক, নেটওয়ার্ক কানেকশন
Weighted Graphপ্রতিটি এজের ওজন থাকে, যা খরচ বা দূরত্ব নির্দেশ করেরাস্তার দূরত্ব, নেটওয়ার্ক ব্যান্ডউইথ
Unweighted Graphএজগুলো ওজনহীন, সাধারণ সংযোগ নির্দেশ করেসাধারণ সংযোগ, যোগাযোগ নেটওয়ার্ক

গ্রাফের ব্যবহারিক উদাহরণ (Python কোড)

Python-এ networkx লাইব্রেরি ব্যবহার করে গ্রাফ তৈরি এবং পরিচালনা করা যায়।

import networkx as nx
import matplotlib.pyplot as plt

# Directed Weighted Graph
G = nx.DiGraph()
G.add_edge("A", "B", weight=3)
G.add_edge("B", "C", weight=5)
G.add_edge("C", "A", weight=2)

# গ্রাফ প্রদর্শন
pos = nx.circular_layout(G)
labels = nx.get_edge_attributes(G, 'weight')
nx.draw(G, pos, with_labels=True, node_color="lightblue", node_size=1500, font_size=16)
nx.draw_networkx_edge_labels(G, pos, edge_labels=labels)
plt.show()

উপসংহার

গ্রাফ হলো একটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা বিভিন্ন জটিল সম্পর্ক ও সংযোগ মডেলিং করতে সহায়ক। Directed, Undirected, Weighted এবং Unweighted গ্রাফের বিভিন্ন প্রকারগুলো বিভিন্ন বাস্তব জীবনের সমস্যার মডেলিংয়ে ব্যবহৃত হয়। গ্রাফ ব্যবহার করে বিভিন্ন ক্ষেত্রের ডেটা বিশ্লেষণ, সংযোগ, এবং দ্রুত সিদ্ধান্ত গ্রহণ সহজ হয়।

গ্রাফের রিপ্রেজেন্টেশন: অ্যাডজেসেন্সি ম্যাট্রিক্স, অ্যাডজেসেন্সি লিস্ট

133

গ্রাফ হল একটি ডেটা স্ট্রাকচার যা নোড (vertices) এবং সংযোগ (edges) নিয়ে গঠিত। গ্রাফের বিভিন্ন ধরনের রিপ্রেজেন্টেশন রয়েছে, যার মধ্যে অ্যাডজেসেন্সি ম্যাট্রিক্স এবং অ্যাডজেসেন্সি লিস্ট সবচেয়ে সাধারণ। নিচে এই দুই ধরনের রিপ্রেজেন্টেশন এবং তাদের বৈশিষ্ট্য বিশদভাবে আলোচনা করা হলো।

১. অ্যাডজেসেন্সি ম্যাট্রিক্স (Adjacency Matrix)

বিবরণ: অ্যাডজেসেন্সি ম্যাট্রিক্স একটি দ্বিমাত্রিক অ্যারে যা গ্রাফের নোডগুলির মধ্যে সংযোগ বোঝাতে ব্যবহৃত হয়। এই ম্যাট্রিক্সের সারি এবং কলামগুলি নোডগুলিকে নির্দেশ করে, এবং একটি এন্ট্রি (i, j) নির্দেশ করে যে নোড i এবং নোড j-এর মধ্যে একটি এজ আছে কি না।

বৈশিষ্ট্য:

  • সাইজ: V×VV×V ম্যাট্রিক্স, যেখানে VV হল নোডের সংখ্যা।
  • স্পেস কমপ্লেক্সিটি: O(V²)
  • গাণিতিক অপারেশন: সংযোগ পরীক্ষা O(1) সময়ে করা যায়, কিন্তু সমস্ত সংযোগগুলি খুঁজে বের করতে O(V²) সময় লাগে।
  • ডেন্স গ্রাফের জন্য কার্যকর: যখন গ্রাফটি ঘন (dense) হয়, তখন এটি কার্যকর।

উদাহরণ:

ধরা যাক একটি গ্রাফে 4টি নোড (0, 1, 2, 3) রয়েছে এবং তাদের মধ্যে কিছু সংযোগ রয়েছে:

    0
   / \
  1---2
   \
    3

অ্যাডজেসেন্সি ম্যাট্রিক্স হবে:

      0  1  2  3
    0  0  1  1  0
    1  1  0  1  1
    2  1  1  0  0
    3  0  1  0  0

২. অ্যাডজেসেন্সি লিস্ট (Adjacency List)

বিবরণ: অ্যাডজেসেন্সি লিস্ট হল একটি ডেটা স্ট্রাকচার যেখানে প্রতিটি নোডের জন্য একটি লিস্ট থাকে, যা সেই নোডের সঙ্গে যুক্ত অন্যান্য নোডের তালিকা ধারণ করে। এটি সাধারণত একটি অ্যারে বা লিস্টের মাধ্যমে সংরক্ষণ করা হয়।

বৈশিষ্ট্য:

  • সাইজ: VV সংখ্যক লিস্ট, যেখানে VV হল নোডের সংখ্যা।
  • স্পেস কমপ্লেক্সিটি: O(V + E), যেখানে EE হল এজের সংখ্যা।
  • গাণিতিক অপারেশন: সংযোগ পরীক্ষা O(V) সময়ে করা যেতে পারে, কিন্তু একটি নোডের সমস্ত প্রতিবেশী খুঁজে বের করতে O(E) সময় লাগে।
  • স্পার্স গ্রাফের জন্য কার্যকর: যখন গ্রাফটি দারুণভাবে বিরল (sparse) হয়।

উদাহরণ:

উপরের গ্রাফের জন্য অ্যাডজেসেন্সি লিস্ট হবে:

0: 1 -> 2
1: 0 -> 2 -> 3
2: 0 -> 1
3: 1

উপসংহার

  • অ্যাডজেসেন্সি ম্যাট্রিক্স এবং অ্যাডজেসেন্সি লিস্ট হল গ্রাফের দুটি মৌলিক রিপ্রেজেন্টেশন পদ্ধতি।
  • অ্যাডজেসেন্সি ম্যাট্রিক্স সহজ এবং দ্রুত সংযোগ পরীক্ষা করতে সাহায্য করে, কিন্তু স্পেস কমপ্লেক্সিটি বেশি হতে পারে।
  • অ্যাডজেসেন্সি লিস্ট স্থান ব্যবহার করতে বেশি কার্যকর এবং স্পার্স গ্রাফের জন্য উপযুক্ত।

গ্রাফের কার্যকারিতা এবং কাঠামো নির্ধারণ করার জন্য সঠিক রিপ্রেজেন্টেশন নির্বাচন করা গুরুত্বপূর্ণ।

গ্রাফ ট্রাভার্সাল: DFS, BFS

157

গ্রাফ ট্রাভার্সাল (Graph Traversal)

গ্রাফ ট্রাভার্সাল হল একটি প্রক্রিয়া যা গ্রাফের সকল নোড (vertices) এবং এজ (edges) পরিদর্শন করে। গ্রাফ ট্রাভার্সালের দুটি প্রধান পদ্ধতি হল ডেপথ-ফার্স্ট সার্চ (DFS) এবং ব্রেডথ-ফার্স্ট সার্চ (BFS)

১. ডেপথ-ফার্স্ট সার্চ (DFS)

বর্ণনা

ডেপথ-ফার্স্ট সার্চ (DFS) হল একটি ট্রাভার্সাল কৌশল যা একটি নোড থেকে শুরু করে তার সর্বাধিক গভীরে প্রবেশ করে যতক্ষণ না এটি একটি শেষ নোড (leaf node) খুঁজে পায়। এরপরে এটি ব্যাকট্র্যাক করে এবং অন্য নোডগুলিতে চলে যায়। DFS সাধারণত স্ট্যাকের মাধ্যমে কার্যকর হয়।

পদ্ধতি

  1. শুরু নোড থেকে প্রবেশ করুন এবং তাকে ভিজিট করুন।
  2. সংযুক্ত নোডগুলির মধ্যে যেকোন একটি নোডে প্রবেশ করুন এবং তাকে ভিজিট করুন।
  3. যদি আরও সংযুক্ত নোড থাকে তবে ধাপ 2 অনুসরণ করুন।
  4. কোনও নোডের সকল সংযুক্ত নোড ভিজিট হয়ে গেলে ব্যাকট্র্যাক করুন।

উদাহরণ কোড (Python):

def dfs(graph, node, visited):
    if node not in visited:
        print(node, end=' ')
        visited.add(node)
        for neighbor in graph[node]:
            dfs(graph, neighbor, visited)

# গ্রাফের উদাহরণ
graph = {
    'A': ['B', 'C'],
    'B': ['D', 'E'],
    'C': ['F'],
    'D': [],
    'E': ['F'],
    'F': []
}

visited = set()
print("DFS Traversal:")
dfs(graph, 'A', visited)  # Output: A B D E F C

২. ব্রেডথ-ফার্স্ট সার্চ (BFS)

বর্ণনা

ব্রেডথ-ফার্স্ট সার্চ (BFS) হল একটি ট্রাভার্সাল কৌশল যা একটি নোড থেকে শুরু করে তার সবার নিকটবর্তী নোডগুলিকে প্রথমে পরিদর্শন করে। এটি সাধারণত কিউ (queue) ডেটা স্ট্রাকচার ব্যবহার করে।

পদ্ধতি

  1. শুরু নোডকে কিউতে যুক্ত করুন এবং ভিজিট করুন।
  2. কিউ থেকে একটি নোড বের করুন এবং তার সকল নোডকে কিউতে যুক্ত করুন।
  3. কিউ খালি না হওয়া পর্যন্ত ধাপ 2 পুনরাবৃত্তি করুন।

উদাহরণ কোড (Python):

from collections import deque

def bfs(graph, start):
    visited = set()
    queue = deque([start])

    while queue:
        node = queue.popleft()
        if node not in visited:
            print(node, end=' ')
            visited.add(node)
            queue.extend(graph[node] - visited)

# গ্রাফের উদাহরণ
print("\nBFS Traversal:")
bfs(graph, 'A')  # Output: A B C D E F

তুলনা: DFS বনাম BFS

বৈশিষ্ট্যDFSBFS
ডেটা স্ট্রাকচারস্ট্যাক (stack)কিউ (queue)
অপেক্ষাকৃত গভীরতাসর্বাধিক গভীরে প্রবেশ করেপ্রথমে নিকটবর্তী নোডগুলি ভিজিট করে
স্পেস কমপ্লেক্সিটিO(h) (h = উচ্চতা)O(w) (w = সর্বাধিক প্রস্থ)
ব্যবহারসাইকেল খোঁজা, গাছের ট্রাভার্সালShortest Path Finding

উপসংহার

DFS এবং BFS হল গ্রাফ ট্রাভার্সালের মৌলিক পদ্ধতি যা বিভিন্ন পরিস্থিতিতে বিভিন্ন ব্যবহার রয়েছে। DFS সাধারণত গভীরতা ভিত্তিক অনুসন্ধানে ব্যবহৃত হয়, যখন BFS সর্বাধিক নিকটবর্তী নোডগুলি অনুসন্ধানের জন্য কার্যকর। প্রতিটি পদ্ধতির সময় এবং স্থান জটিলতা ভিন্ন, তাই সমস্যা অনুসারে সঠিক পদ্ধতি নির্বাচন করা গুরুত্বপূর্ণ।

Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...